CLAIMS 

What is claimed is: 

\ l. A method for energy and power estimation of a core-model 
bas^d embedded system, the method including: 

jpturing gate-level energy simulation data; 
depbqying the captured gate-level simulation data in an algorithmic- 
level executabl^sspecification, wherein the captured gate-level data 
simulation data correlates to a plurality of instructions; and 

executing the algorithmic-level executable specification to obtain 
energy estimations for eetah instruction; 

2. A method of modeling energy and power requirements for a 
system-on-a-chip, the modelingVnethod including: 

deploying a circuit model o\the system-on-a-chip by selecting at 
least one parameterized instruction-fcased core model and instantiating 
the at least one parameterized instruction-based core model; 
executing the circuit model; 

analyzing the estimated energy requ\rements of the circuit model; 

and 

outputting the estimated energy requirements for the circuit model. 

3. The method of modeling energy and Vower requirements for 
a system-on-a-chip as claimed in claim 2, wherein tnte least one 
parameterized instruction-based core model includes toggle counts for a 
plurality of implementations of the deployed circuit modef 

4. A method for creating a library of instruction-ba^d core 
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energy models, the method including: 

deploying a circuit model using a hardware description language; 
defining a plurality of high-level instructions correlating to functions 
supp\)Vted by the circuit model; 

^acquiring gate-level energy simulation data for each component 
comprisingwthe circuit model; 

collect^ a plurality of toggle count sets corresponding to each of 
the plurality of hVoh-level instructions; 

assigning each of the plurality of toggle count sets to one of the 
plurality of high-level instructions, thereby creating an instruction-based 
core energy model; and\ 

implementing thevtjstruction-based core energy model within the 
library that is realized as a\)ok-up table. 

5. The method foryfcreating a library of instruction-based core 
energy models as claimed in cUmri 4, wherein the step of assigning each of 
the plurality of toggle count sets\oone of the plurality of instructions 
further includes increasing the numbV of high-level instructions to reduce 
data dependency. \ 

6. A computer program product r^r use in a computer system 
in which core models are accessed by an application program, the 
computer program product including a computer usable medium bearing 
computer executable code, the computer executable cis^de including: 

a first executable code portion for determining if the core model 
should simulate an idle state or execute an instruction, baseb\upon 
whether the core model is called by another core model or it is caHed by a 
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\ a second executable code portion for determining if resources 
required by the core model are free, and claiming the free resources; 

\a third executable code portion for adding an idle energy value to 
an energyyaccumulator; 

a fourth executable code portion for determining if a clock counter 
are decrementeavthereby collecting data about the elapsed time and 
calculating the consumed power from the energy data; 

a fifth executabl^code portion for simulating execution of a 
predetermined instruction ;\nd 

a sixth executable code\portion for adding energy value to the 
energy accumulator; \ 

7. A computer program product for use in a computer system 
in which core models are accessed by an application program, the 
computer program product including: \ 

a computer usable medium bearing Computer programming 
statements for enabling the computer systerAto create at least one circuit 
model object for use by the application program; 

the computer programming statements including a class library 
expressing an inheritance hierarchy and including art least one core model 
base class for constructing instances of the at least one circuit model 
object, the core model base class representative of a circuit element; 

the at least one core model base class including, as a respective 
subclass thereof, an autonomous core model class defining\at least one 
core model member function for directly interacting with theNapplication 
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program; and 

the at least one core model member function simulating an 
instruction associated to the circuit element, the circuit element providing 
onWtime predetermined data correlated to the simulated instruction. 

In a computer system having an application program that 
models the eiwgy and power requirements of a system-on-a-chip circuit 
design, an energy aqd power modeling method for an application program 
to access and execute a'parameterized core model of a circuit element, 
the method including: 

providing to the applicatio\program a circuit object representing a 
modeled circuit, the circuit object havtag instantiated at least one 
parameterized core model having at leasusone member function for 
simulating functions assigned to circuit element, wherein the at least one 
member function outputs an energy and power estimation correlated with 
each simulated function; \ 

sending a message from the application prograrato the circuit 
object to invoke the at least one member function, thereov executing a 
simulated function of the circuit element; and \ 

sending a message from the circuit object to the application 
program embodying the energy and power estimation with respect ro the 
invoked member function. \ 



- 44 - 



